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(54) Converting numbers between measurement systems based upon semantically labeled 
strings 



(57) A method, system, and apparatus are provkJed 
for converting numbers between different units of meas- 
urement. When a siring of text is entered into an appli- 
cation program, the string is analyzed to determine 
whether the string of text Includes a number having an 
associated unit name, if the string of text includes a 
number having an associated unit name, the number is 
semantically labeled with schema information that Iden- 
tifies the unit name as a source unit of measurement. 



When a selection is received of the number or an indi- 
catk>n that the number is labeled with schema informa- 
tion, a list of actions may be provided identifying con- 
version options available for the number. One of the con- 
version options may then be selected resulting in the 
conversk}n of the selected numt>er to the destination 
unit of measure identified by the selected action. The 
converted number may then be inserted into the string ■ 
of text to replace the selected number along with a unit 
name corresponding to the destination unit of measure. 



Csl 

< 

CO 
Csl 

in 

iO 
CO 



CL 
HI 





iNPinyoinrvT 

CONTROUXR 



SYSTEM 



RANDOM 
ACCESS 
MEMORY 



READ 
ONLY 
M&dOKYl 



205^ nL 



220 



OP£RATTNG 
SYSTEM 



AFPUCAtlON 
PROGRAM 



MASSSTORAOt 
DEVICE 



RECOGmZER 
PLUG-IN 



CO NVER SEON 
SETTINGS 



DOCUMENT 



ACTION PLUG-IN 



l ANOU ACE 
SETTINGS 



BEST AVAILABLE COPY 



EP 1361 523 A2 




28 



FigJB. 



1 



EP 1 361 523 A2 



2 



Description 
Technical Field 

[0001] Embodiments of the present invention relate to 
the field of unit measurement conversion. More partlc- 
utarly* embodiments of the invention relate to the field 
of converting numbers between measurement systems 
based upon semanticany iat)eied strings. 

Background of the Invention 

[0002] As a result of the advent and explosion of the 
Internet and the World Wide Web ("Web"), computer us- 
ers today frequently receive electronic documents from 
other users located In countries throughout the world. 
Electronic documents such as these often include num- 
bers expressed in a unit of measurement utilized in the 
sender's particular country. For Instance, users located 
in the United States are likely to express numbers in the 
Imperial system of measuren^nt (e.g. Inches, feet, 
etc.)» while European users are likely to express num- 
bers in the Metric system of measurement (e.g. centim- 
eters, kitometers. etc.). 

[0003] When users receive electronic documents 
having numbers expressed in measurement systems 
other than the system used in their native countiy, users 
may need to convert the numt>ers to their local meas- 
urement system to understand the meaning of the 
numt>er. For instance, a user may want to convert a 
numt>er expressed in degrees Fahrenheit, which Is a 
unit of measure for temperatures commonly used in the 
United States, to degrees Celsiuis, which is a unit of 
measure for temperatures commonly used In Europe. 
However, converting numbers between measurement 
systems in this manner has heretofore been difficult for 
a user to accomplish easily. 

[0004] Prevk>usly, if a user wanted to convert a 
numt>er contained in an electronic document, such as a 
word processing document, between measurement 
systems, the user would first have to copy the number 
to be converted to a clipboard. The user would then 
paste the number into an external program or Web site 
capable of converting the number to the cfesired destl-i 
nation unit of measure. Once the external program or 
Web site had completed the conversion, the user may 
copy the converted number to the clipboard and then 
paste the converted number back into the electronic 
document. Although systems such as these do allow a 
user to convert a number between measurement sys- 
tems, these systems can be difficult for to use because 
of the large number of steps required to complete the 
conversion. Moreover, these previous solutions require 
the user to perform the conversion using the user inter- 
face language of the conversion program or Web site. 
This can be extremely frustrating for a user that does 
not understand the language of the conversion program 
or Web site - 



[0005] Therefore, in light of the above, there ts a need 
for a method, system, and apparatus for easily convert- 
ing numbers between measurement systems that do not 
require a user to utilize an external application or Web 
5 site to convert nunrtbers between measurement sys- 
tems. Moreover, there is a need for a method, system, 
and apparatus for converting numbers between sys- 
tems of measure that can present conversion options to 
the user in a user-selected user interface language. 

Summary of the Invention 

[0006] Embodiments of the present invention solve 
the above-described problems by providing a method, 

t5 system, and apparatus for easily converting numbers 
t>eh/veen measurement systems and units that do not 
require the use of an external application or Web site to 
convert the numbers. Moreover, embodiments of the 
present invention provkJe a method, system, and appa- 

20 ratus for converting numbers t>etween units that can 
present conversion options to the user in a user-select- 
ed interface language. Moreover, emtHxjiments of the 
invention provide an extensible architecture through 
which a user may add conversion oiles that enable con- 

25 version of numbers between measurement systems not 
initially supported. 

[0007] According to one actual embodiment of the 
present invention, a method is provided for converting 
a number between measurement systems in a system 

^ for creating and editing an electronic document . Accord- 
ing to this embodiment of the invention, software nKXl- 
ules are executed in conjunction with a sofhA/are appfi- 
cation for creating and editing an electronic document 
that allow the convenient conversion of numbers be- 

35 tween measurement units. When a user types a string 
of text, such as a paragraph into the software applica- 
tion, the string is analyzed to detennine whether the 
string of text Includes a number having an associated 
unit name. For instance, a user may type the number 

40 '10* and the associated unit name "km*, for kilometers. 
If the string of text Includes a number having an associ- 
ated unit name, the number is semantically labeled with 
schema information that identifies the unit name as a 
source unit of measure. For instance, if a string of text 

45 includes the number "10" followed by the unit of meas- 
ure 'km', schema information will be associated with the 
number indicating that the numk>er is expressed with a 
source unit of measure. 

[OOOS] Once a number having an associated unit 
50 name has been identified within a string of text, such as 
a paragraph, the application may display an indication 
to the user that the number has been semantically la- 
beled. This indication also identifies to the user that ac- 
tions may be perfonmed on the number. When a selec- 
55 tion is received of Ihe numtjer or the indication, a list of 
actions may be provided to the user Identifying conver- 
sion options available for the number. For instance, if 
the identified number includes an associated unit name 
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"m", for meters, an action menu Item may be displayed 
to the user for converting the number to feet or yards. 
Other types of conversion options may also be present* 
ad to the user for converting the number. 
[0009] According to one embodiment of the invention, 
a cun-ent user interface language setting for the appli- 
catton program is determined prior to providing the list 
of actions to the user. When the user selects the list of 
actions, the available actions are displayed to the user 
in a language speaTied by the current user interface lan- 
guage setting. In this manner, the user Is always pre- 
sented the conversion options In the current user inter- 
face language. Actions may also be included in the list 
of actions onJy for conversions supported for the current 
user interface language setting and may also be speci- 
fied as being enabled for use with all user interface lan- 
guages. 

p)010] After the list of actions has been displayed to 
the user, a selection of one of the actions may be re- 
ceived. In response to receiving the selectlc^ of a con- 
version action, a converted number may be generated 
by converting the selected number to the destination 
unit of measure identified by the selected action. Once 
the conversion is completed, the converted number and 
its associated unit name may be inserted into the string 
of text to replace the selected number and its associated 
unit name. According to various emt>odiments of the 
present invention, a document object model supported 
by the application program may be utilized to insert the 
converted number into the strirjg of text. Altemativeiy, 
the converted number may be displayed to the user. 
[0011] According to another embodiment of the 
present Invention, a system is provided for converting a 
number between measurement systems. According to 
this embodiment of the invention, the system includes 
a recognizer plug-in capable of receiving a portion of an 
electronic document as a string of text from an applica- 
tion program. For instance, the recognizer plug-in may 
receive a paragraph of text from an application program 
as it is typed by the user. Once the recognizer plug-in 
has receh^ed the string of text, the recognizer plug-in 
analyzes the string of text to determine whether the 
string of text includes a number having an associated 
unit name. If the string of text includes a number having 
an associated unit name, the recognizer plug-in seman- 
tlcally labels the number with schema information iden- 
tifying the unit name as a source unit of measure and 
identifying the language used to express the string of 
text. This inlormation is tiien passed by the recognizer 
plug-In back to the application program. 
[0012] According to one embodiment of the invention, 
the system also includes an application program for cre- 
ating and editing an electronic document. For instance, 
the application program may comprise a word proces- 
sor, a spreadsheet application program, an e-mail ap- 
plication which includes editing functions, or other types 
of application programs lor creating and editing elec- 
tronic documents. According to this embodiment of the 



Invention, the application program is capable of display- 
ing the string of text along with an indication that the 
number has t»een semantically labeled by the recogniz- 
er plug-in. This indication may comprise a user interface 

5 object for indicating to a user that the numt>er has been 
senDanticaliy labeled and that conversion actions may 
l>e perfomried on the number. 
[0013] The application program may also be opera- 
tive to receive a selection of the number or the indication 

10 and to provide a list of actions that may be performed 
on the number to convert the number to another meas- 
urement unit The application may then receive the se- 
lection of one of the list of actions and provide the se- 
lection and the number to an action plug-in. 

15 [001 4] The system also includes an action plug-in that 
is capable of generating a converted numt>er by con> 
verting the selected number to the destination unit of 
measurement identified by action selected from the list 
of actions. The action plug-in is also operative to replace 

20 the selected number and its associated unit name with 
the converted number and Its associated unit name in 
the string of text. According to one actual embodiment 
of the invention, the action plug-in may replace the 
number with the converted numl>er tn the string of text 

25 by accessing a document object model provided by the 
application program. Alternatively, the converted 
number and its associated unit name may be displayed. 
[0015] According to various embodiments of the 
present invention, the system provided herein may also 

30 include an action plug-in ttnat is operative to register with 
the application program prior to pertorming any conver- 
sion functions. As a part of the registration procedure, 
the action plug-in may provide the list of actions that may 
be performed on the number to convert the number to 

35 another measurement system to the application pro- 
gram. Moreover, when creating the list of actions, the 
action plug-In may detemiine a current user interface 
language setting for the application program and gen- 
erate the action menu items In a language specified by 

40 the current user interface language setting. Additionatly, 
the action plug-in may also consult a conversion settings 
file to generate action menu items for each source unit 
name enabled for use with all enabled languages and 
for each source unit name enabled for use with the cur- 

<5 rent user interface language. The contents of the con- 
version settings file may be modified by a user to enable 
conversion between measurement systems other than 
those initially defined in the conversion settings file. 
[0016] Other embodiments of the present invention 

so provide a computer-controlled apparatus and a compu- 
ter-readable medium for converting numbers between 
measurement systems based on semantically labeled 
strings. These and other details regarding the various 
embodiments of the invention will become more appar- 

55 ent from the detailed description that follows. 
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Brig! Description of the Drawings 
[0017] 

FIGURE 1A is a block diagram showing the archi- 
tecture of a personal computer that provides an il- 
lustrative operating environment for embodiments 
of the present invention; 

FIGURE IB is a block diagram showing the format 
and contents of a conversion settings ftte utilized In 
various embodiments of the present invention to de- 
fine available conversions; 
FIGURE 2 is a block diagram that shows a software 
architecture for recognizing, labeling, and perform- 
ing actions on recognized strings of text according 
to various embodiments of the present Invention; 
FIGURES 3A-3D are screen diagrams showing 
screen displays including an action menu for con- 
verting numbers between measurement systems 
provided by various embodiments of the present in- 
vention; 

FIGURE 4 is a flow diagram showing an Illustrative 
routine for registering an action plug-in with an ap- 
plication program according to one actual embodi- 
ment of the present invention; 
FIGURE 5 is a flow diagram showing an illustrative 
routine for processing a string input provided at an 
applk^tion program according to one actual em- 
bodiment of the present invention; 
FIGURE 6 is a flow diagram lllustrafing the opera- 
tion of a recognizer plug-in software module provid- 
ed according to one actual embodiment of the 
present Invention; 

FIGURE 7 is a flow diagram illustrating a routine for 
processing the selection of a semantically catego- 
rized number according to one actual embodiment 
of the present inventk^n; and 
FIGURE 8 is a flow diagram showing a routine for 
executing an action plug-in for converting numbers 
between measurement units according to one ac- 
tual embodiment of the present invention. 

Detailed Description of an Illustrative Emt>odiment 

[0018] As described briefly above, embodiments of 
the present invention provide a method, system, appa- 
ratus, and computer-readable medium for converting 
numbers between units of measure. In the following de- 
tailed description, references are made to the accom- 
panying drawings that tom> a part hereof, and in which 
are shown by way of illustration specific embodiments 
or examples. These eml^odiments may be combined, 
other embodiments may be utilized, and structural 
changes may be made without departing from the spirit 
and scope of the present invention. The following de- 
tailed description is, therefore, not be taken in a limiting 
sense, and the scope of the present invention is defined 
by the appended claims and their equivalents. 



[001 9] Referring now to the drawings, in which like nu- 
merals represent Wke elements through the several fig- 
ures, aspects of the present Invention and the 9lustrative 
operating environment will be described. FIGURE 1A 

5 and the following discussion are Intended to provide a 
brief, general description of a suitable computing envi- 
ronment in which the invention may be Implemented- 
While the invention will be described in the.general con- 
text of program modules that execute in conjunction with 

10 an applk»tion program that runs on an operating system 
on a personal computer, those skilled in the art will rec- 
ognize that the Invention may also be implemented in 
combination with other program modules. Additional as- 
pects of an illustrative operating environment and soft- 

IS ware architecture for implementing the various embod- 
iments of the present invention are described In U.S, 
Patent Application No. 09/588,41 1 , entitled "Method and 
System for Semantk^ally Labeling Strings and Providing 
Actions Based on Semanticatty Labeled Strings', which 

20 Is expressly incorporated herein by reference. 

[0020] Generally, program modules include routines, 
programs, components, data structures, and other 
types of stmctures ttwit perform particular tasks or im- 
plement particular abstract data types. Moreover, those 

25 skilled In the art will appreciate that the invention may 
be practk^ed with other computer system configurations. 
Including hand-held devices, multiprocessor systems* 
microprocessor-based or programmable consumer 
electronics, minicomputers, mainframe computers, and 

30 the Tike. The invention may also be practiced in distrib- - 
uted computing environnnents where tasks are per-* 
formed by remote processing devices that are linked 
through a communications network. In a distributed 
computing environment, program modules may be lo- 

35 cated in both local and remote memory storage devices, 
[0021] Turning now to FIGURE 1A. an illustrative 
computer architecture for a personal computer 2 for 
practicing the various embodiments of the invention will 
be described. The computer architecture shown in FIG- 

40 URE 1A illustrates a conventional personal computer, 
including a central processing unit 4 ("CPU"), a system 
memory 6, including a random access memory 8 
("RAM") and a read-only memory CROM") 10, and a 
system bus 12 that couples the menwry to the CPU 4. 

45 A basic input/output system containing the basic rou- 
tines that help to transfer information between elements 
within the computer, such as during startup, is stored in 
the ROM 10. The personal computer 2 further includes 
a mass storage device 14 for storing an operating sys- 

50 tern 16, application programs, such as the application 
program 205, and data. 

[0022] The mass storage device 14 Is connected to 
the CPU 4 through a mass storage controller (not 
shown) connected to the bus 12. The mass storage de- 
55 vice 14 and its associated computer-readable media 
provide non-volatile storage for the personal computer 
2. Although the description of computer-readable media 
contained herein refers to a mass storage device, such 
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as a hard dsk or CE>ROM drive, it should be appreci- 
ated by those skilled in the art that ooiTiputer-raadat>ie 
media can be any available media that can be accessed 
by the pereonai connputer 2. 

(0023] By way of example, and not limitation, compu- 
ter-readable media may comprise computer storage 
media and communicatjon media. Computer storage 
media includes volatile and non-volatile, removable and 
non-removable media implemented in any method or 
technology for storage of information such as computer- 
readable instructions, data structures, program mod- 
ules or other data. Computer storage media includes, 
but is not limited to, RAM, ROM, EPROM, EEPROM. 
Hash menfK>ry or other solid state memory technology, 
CD-ROM, DVD, or other optical storage, magnetic cas- 
settes, magnetic tape, magnetic disk storage or other 
magnetic storage devices, or any other medium which 
can be used to store the desired Information and which 
can be accessed by the computer 
[0024] According to vanous embodiments of the in- 
vention, the personal computer 2 may operate in a net- 
worked envtronn^nt using logical connections to re- 
mote computers through a TCP/I R network 1 8. such as 
the Internet. The personal computer 2 may connect to 
the TCP/IP network 18 through a network interface unit 
20 connected to the bus 12. It should be appreciated 
that the network interface unit 20 may also be utilized to 
connect to other types of nelwori<s and remote computer 
systems. The personal computer 2 may also include an 
Input/output controller 22 for receiving and processing 
input from a number of devices, including a keyboard or 
mouse (not shown). Similarly, an input/output controller 
22 may provide output to a display screen, a printer, or 
other type of output device. 

[0025} As mentioned briefly above, a number of pro- 
gram modules and data files may be stored in the mass 
storage device 14 and RAM 8 of the personal computer 
2, including an operating system 16 suitable for control- 
ling the operation of a networked personal computer, 
such as the WINDOWS XP operating system from MI- 
CROSOFT CORPORATION of Redmond, Washington. 
The mass storage device 14 and RAM 8 may also store 
one or more application programs. In particular, the 
mass storage device 14 and RAM 8 may store an appli- 
catk)n program 205 for creating and editing an electronic 
document 24. For instance, the application program 205 
may comprise a word processing application program 
and the electronic document 24 may comprise a word 
propessing document. The application program 205 
may also comprise a spreadsheet application program 
and the electronic document 24 comprise a spread- 
sheet. Similariy. the application program 205 may com- 
prise an electronic mail application program and the 
electronic document 24 may comprise an electronic mail 
message. Application programs for creating and editing 
other types of electronic documents may also be used 
with the various embodiments of the present invention. 
[0026] Embodiments of the present invention provide 



program modules for use in conjunction with the appfi- 
oation program 205 that convert numbers contained 
within the electronic document 24 between units of 
measure, also refen^ed to herein as measurement units 

5 Of measurement systems. In partteular, embodiments of 
the invention provide a recognizer plug-in 220 and an 
action plug-in 225. As will be described In greater detail 
below, the recognizer plug-in 220 recognizes numbers 
having an associated unit name contaif>ed within an 

10 electronic document 24 and labels the numbers with se- 
mantic information identifying the unit name as a source 
unit of measure. The recogrtizer plug-in 220 then passes 
this inJormatfon to the application program 205 for use 
by the action ptug-ln 225. The action plug-in 225 par- 
ts forms actions on the recognized numbers for converting 
between units of measure. The availat>le conversions 
are defined in the conversion settings file 28. Additional 
details regarding the conversion settings file 28 are de- 
scrtt>ed below with reference to FIGURE 1 B. 

20 [0027] According to various embodiments off the 
present Invention, the action plug-in 225 may also gen- 
erate a list of actions that may be performed on a given 
number. As a pari of this process, the action plug-in 225 
may query language settings 26 of the application pro- 

25 gram 205 or operating system 16. The language set- 
tings 26 specify tiie current user interface language. The 
list of actions may then be created In the current user 
Interface language. Moreover, the action plug-in 225 
may also consult the conversion settings file 28 to gen- 

30 erate action menu items for each source unit name en- 
abled for use with all enabled languages and for each 
source unit name enabled for use with the current user 
Interface language. Additional details regarding the op- 
eration of the recognizer plug-in 220 and the action plug- 

35 in 225, including the use of the conversion settings We 
28 and the language settings 26, will be described in 
greater detail below. 

[0028] Referring now to FIGURE 1 B, various aspects 
of the conversion settings file 28 will be described. As 

<o discussed briefly above, the conversion settings file 28 
is utilized by both the recognizer plug-in 220 and the 
action plug-in 225. In particular, the recognizer plug-in 
220 utilizes portions of the conversion settings file 28 to 
determine the source unit names thai should be recog- 

45 nized within a string of text, and the action plug-in 225 
utilizes the conversion settings file 28 to create the ac- 
tion menus that should be presented to the user and to 
actually perform conversions. Additional details regard- 
ing the use of the conversion settings file 28 by the rec- 

50 ognizer plug-in 220 and the action plug-in 225 will be 
described in greater detail below. 
[0029] As shown in FIGURE IB, the conversion set- 
tings file 28 comprises a data file having fields 50A-50J. 
The field 50A contains a locale identification CLCID") 

55 number for which a particular conversion should be en- 
abled. As known to those skilled in the art, when used 
in conjunction with the WINDOWS XP operating system 
from MICROSOFT CORPORATION of Redmond, 
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W^ington. the LCID is an identifccation number used 
to identify locales and languages. The LCID is used 
herein to ensure that conversion options will be present- 
ed to the user only for conversions that are enabled for 
use with the currently enabled language. Alternatively, 
the fleW 50A may rndude the phrase 'AIX*, thereby en- 
abling the conversion for use with all enabled languag- 
es. Additional details regarding the use of the field 50A 
will be described below. 

[0030] The conversion settings file 28 also includes a 
field 508 representing the source unit name. The source 
unit name is the name of the source unit of measure that 
is associated with a recognized number. The recognizer 
plug-In 220 uses the field 50B to identify those source 
unit names that It should recognize. The conversion set- 
tings file 28 also includes a field 50C that includes a 
source description corresponding to the source unit 
name identiried in the field SOB. The contents of the field 
50C may be localized for a particular locale. The con- 
version settings file 28 also includes a field 500 that In- 
dicates whether a space is located between the source 
unit name and number. Some regional fomiats utilize a 
space between a number and a unit name while others 
do not. The field SOD is therefore utilized by the recog- 
nizer plug-in 220 to recognize numbers expressed using 
either format. The conversion settings file 28 also in- 
dudes a field 50E that defines whether the case of the 
source unit name should be considered by the recog- 
nizer plug-in 220. 

[0031] The conversion settings file 28 also includes 
the field 50F wWch contains data identifying ttie desti- 
nation unit name and a field 50G which contains data 
Identifying the destination description. As with the field 
50C, the field 50G may be localized for a particular lo- 
cale. A field 50H is also included that indicates whether 
a space should be placed between the destination 
number and its associated unit name in the conversion 
result. The field 50H is utilized by the action plug-in 225 
when formatting conversion results. 
[0032] The conversion settings file 28 also includes a 
field 501 indicating the number of decimal places that 
should be utilized when rounding the converted result. 
The field 50i may be changed for each conversion. Typ- 
ically, the rounding precision value contained in field 501 
is adjusted for conversions where the destination value 
is much larger or much smaller than the source number. 
[0033] The conversion settings file 28 also Includes a 
field 50J which defines the conversion ratio or fomiula 
reference that should be utilized for a particular conver- 
sion. Where a conversion is performed by multiplying by 
a coefficient, the field 50J contains the coefficient. 
Where a conversion is perfomied utilizing a more com- 
plex equation, the field 50J may include a formula ref- 
erence to the appropriate formula. For instance, the field 
50J may include a reference to a formula for converting 
Celsius values to Fahrenheit values, such as "CTOF*. 
Other types of formula references may also be provided 
for performing more complex conversions. 



[0034] The conversion settings file 28 shown in FIG- 
URE IB indudeis several illustrative conversion entries 
52A-52E. The entry 52A con-esponds to a conversion 
from kilometers to miles and is enabled for all languag- 

5 es. The entry 52B con-esponds to a conversion from de- 
grees Celsius to degrees Fahrenheit and is also enabled 
for all languages. The entrfes 52C-52D convert between 
Swedish long" miles and kibmeters and are only ena- 
bled when the active user interface language corre- 

10 spends to the LCID •1054/ The entry 62E coresponds 
to a conversion from kilometers to yards and is also en- 
abled for all languages. 

[0035] It should be appreciated by the reader that the 
entries 52A-52E are merely illustrative examples of the 

15 types of conversions that may be defined in the conver- 
sion setfings file 28 and that other types of conversions 
may be similarly defined. In particular, conversions may 
be defined between miles and kilometers. Indies and 
centimeters, millimeters and inches, feet and centime- 

20 ters, meters and feet, yards and meters, acres and hec- 
tare, U.K. pints and liters, US. pints and liters, liters and 
gallons, ounces and deciliters, quarts and liters, pounds 
and krtograms, miles per hour and kilometers per hour, 
and other measurement units. Moreover, it should be 

25 appreciated that additional conversions may be defined 
by adding an appropriate entry to the conversion set- 
tings file 28 defining the new conversion. 
[0036] Referring now to FIGURE 2, an Illustrative soft- 
ware architecture for use in conjunction with the vartous 

30 embodiments of the present Invention will be described. 
The architecture shown in FIGURE 2 includes an appli- 
cation program 205, such as a word processor applica- 
tion program, a spreadsheet application program, or 
other type of appUcatton program for creating and edil- 

35 ing electronic documents. The application program 205 
may also comprise a Web browser. 
[0037] The application program 205 is able to com- 
munteate with a recognizer dynamically linked library 
("DLL") 210 and an action DLL 215. As will be described 

^ in greater detail below, the recognizer DLL 21 0 controls 
one or more recognizer plug-ins 220A-220N and the ac- 
tion DLL 215 controls one or more action plug-ins 225A- 
225N. 

(0038] According to one embodiment of the invention, 
45 the recognizer plug-in$ 220A-220N and the action plug- 
ins 225A-225N are automation servers. Automation 
senders are well-known software components that are 
assembled Into programs or add functionality to existing 
programs running on the WINDOWS XP operating sys- 
50 tem from f^lCROSOFT CORPORATION of Redmond, 
Washington. Automation servers may be written in a va- 
riety of computing languages and can bo plugged and 
unplugged from a program at runtime without having to 
recompile the program, 
55 [0039] The recognizer DLL 2 1 0 handles the distribu- 
tion of text strings from an electronic document being 
edited by the application program 205 to the Individual 
recognizer plug-Ins 220A-220N. The recognizer plug- 
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ins 220A-220N reco^ize particular strings In an elec- 
tronic document, such as a word processing document 
or a spreadsheet document. The recognizer plug-ins 
220A-220N may be packaged with the application pro- 
gram module 205 or they may be written by third parties 
to recognize particular strings of interest. Typically, the 
recognizer DLL 210 passes strings to the recognizer 
plug-ins 220A-220N in single paragraphs or cell value 
irKsrements. However, strings may be passed to the rec- 
ognizer plug-Ins 220A*220N in other sizes and fonmats. 
[0040] As part of recognizing certain strings as Includ- 
ing semantic Information, the recognizer plug-Ins 220A- 
220N determine which strings are to be labeled and how 
they are to be labeled. After receiving these results from 
the various recognizer plug-Ins 220, the recognizer DLL 
210 sends semantic categories to the application pro- 
gram module 205. According to one a«^ual embodiment 
of the invention, a recognizer plug-in 220 is provided for 
recognizing strings as containing numbers having an 
associated unit name. According to this embodiment of 
the invention, the semantic category comprises schema 
Information that identifies the unit name as a source unit 
of measure. The schema infomnation may also include 
Information identifying the language In which the string 
of text is expressed. This information is returned to the 
recognizer DLL 21 0 by the recognizer plug-in 220 along 
with other Infonnation that inay be utilized by a cone- 
sponding action plug-in 225, such as a copy of the 
number, the source unit name, and the language that 
the string of text is expressed in. Additionally, the rec- 
ognizer plug-in 220 may return information identifying 
the location of the number within the text siring, indud- 
ing the length of the text string and the character number 
of the first letter of the number. 
[0041] It should be appreciated that each of the rec- 
ognizer plug-Ins 220A-220N are executed separately. 
The recognizer DLL 210 is responsible for handling the 
asynchronidty that results from different recognizer 
plug-ins 220A-220N returning results at different times. 
In this manner, various types of data may be recognized 
within a text string and different actions provided for 
each semantically labeled string. Additional details re- 
garding the operation of the recognizer plug-in 220 for 
recognizing numbers will be described below with refer- 
ence to FIGURES 3-8, 

[0042] After a string is labeled by a recognizer plug- 
in 220A-220N, schema information is sent to the appli- 
cation program module 205. A user of the application 
program module 205 may then execute actions that are 
associated with the schema infonnation on the recog- 
nized string. The action DLL 215 manages the action 
plug-ins 225A-225N thai are executed in order to per- 
form the actions. As with the recognizer plug-ins 220A- 
22N, the action plug-ins 225A-225N may be packaged 
with the application program module 205 or written by 
third parties to perform particular actions that are of in- 
terest. The action plug-ins 225A-225N provide possible 
actions to be presented to the user based upon the 



schema information, or type label, associated with the 
string. As will be described In greater detail below, the 
Kst of actions provided to the user Is dynamically gener- 
ated for each schema type. This information is then pro- 

5 vided to the application program 205 which displays the 
Cst of actions to the user when the string is selected. 
[0043] After an action has been chosen from the Ust 
of actions, the action DLL 21 5 manages the appropriate 
action plug-in 225A-225N emd passes the necessary in- 

w formatton between the action plug-in and the application 
program module 205 so that the action plug-in may ex- 
ecute the desired action. Typically, the applicallon pro- 
gram module 205 sends the action DLL 215 ar) automa- 
tion request to invoke the action the user has selected. 

75 As will be described in greater detail below, according 
to one embodiment of the Invention, an action plug-in 
225 is provided that converts recognized numbers to 
other units of measure. Addition details regarding the 
operation of the action ptug-ln 225 and the schema rrv 

20 formation utilized to Identify different source unit names 
will be described in greater detail below with reference 
to FIGURES 3-8. 

[0044] Referring now to FIGURES 3A-3D, an illustra- 
tive user inteif ace provided by the various embodiments 

25 of the present Invention will be described. As shown in 
FIGURE 3A, a number 32 Including an associated unit 
name may be typed by a user into an application pro- 
gram 205, such as a word processor, as a part of a string 
of text. Once the user has provided the string of text, the 

30 String of text is provided to a recognizer plug-In 220 that 
recognizes numbers contained within the siring of text, 
such as the number 32. The number 32 having an as- 
sociated unit name Identified by the recognizer plug-in 
220 is identified to the application program module as a 

35 type of semantic information upon which actions may 
be performed. Therefore, the application program mod- 
ule 205 provides an indication to the user that actions 
may be performed on the number 32, This indication 
may be provided to the user by highlighting the number 

40 32 or providing a user Interface Indication 34 In proximity 
to the numl>er 32. 

[0045] When the number 32 or the indication 34 is se- 
lected by a user, a list of actions is displayed that may 
be performed on the number to convert the number to 

45 another unit of measure. This list of actions may com- 
prise a dropdown menu 36 having one or more menu 
Items corresponding to the list of actions that may be 
performed on the numlier 32. According to one embod- 
iment of the invention, the contents of the dropdown 

50 menu 36 may be displayed in one of many different lan- 
guages. The language in which the dropdown menu 36 
is displayed is based on a current interface user lan- 
guage lor the application program module 205 or the 
operating system 16. In this manner, international users 

55 throughout the worid will be displayed a dropdown menu 
36 In their currently installed and active user interface 
language. 

[0046] As shown in FIGURE 3A. the dropdown menu 
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36 tndudes another indication of the number 32 to be 
converted. The dropdown menu 36 also tndudes a list 
of actions 38 that may be perfom>ed to convert the 
number 32 to other measurement systems. According 
to on© embodiment of the Invention, the list of actions 
38 displayed in the dropdown menu 36 is limrted to con- 
version options specilied for use with the currently ena- 
bled user Interface language on the personal computer 
2. In this manner, actions for converting numbers not 
relevant to the currently enabled language of the per- 
sonal computer 2 will not t>e shown in the dropdown 
menu 36. 

[0047] As shown in FIGURE 3A, the application pro- 
gram module 205 also adds menu items 44A and 44B 
to the dropdown menu 36. The selection of Item 44A 
removes the semantic labeling from the selected text. 
Other recognized text in the same (or other) documents 
will remain labeled, and newly typed text wOl still be sub- 
iect to continued recognition and lat>eiing. The selection 
of item44B provides a list of user selectable preferences 
defining the operation and behavior of the recognizer 
and action plug-ins. 

{004S] As described briefly above, when a number 32 
having an associated unit name is recognized by the 
recognizer plug-in 220, the number 32 is labeled with 
schema information identifying the associated unit 
name as a source unit of measure. Additionally, the lan- 
guage of the string of text may also be identified in the 
schema information. This schema infonnation is then re- 
turned to the application program 205 and Is utilized by 
the action plug-in 225 to determine the appropriate list 
of actions 38 that should be included in the dropdown 
menu 36, In this manner, only conversion operations 
consistent with the source unit of measure and the lan- 
guage used to express the string of text are provided to 
the user via the dropdown menu 36. 
t0049J The number 32 shown in FIGURE 3A is ex- 
pressed in kilograms. Ttierefore, the dropdown menu 35 
includes actions in the list of actions 38 for converting 
the number 32 to pounds, and to stones and pounds. 
Similarly, the number 32 shown in FIGURE 3B is ex- 
pressed in meters. Therefore, the dropdown menu 36 
includes actions In the list of actions 38 for converting 
the number 32 to feet and to yards. Likewise, the 
number 32 shown in FIGURE 3D is shown degrees Cel- 
sius. Therefore, the dropdown menu 36 includes only 
an action for converting the number 32 from degrees 
Celsius to degrees Fahrenheit, Also, the list of actions 
38 shown in FIGURES 3A, 3B, and 3D is displayed Eng- 
lish. It should be appreciated, however, that the drop- 
down menu 36 would appear in another language if a 
language other than English was selected as the ounrent 
user interface language on the personal computer 2. 
[0050] As shown in FIGURE 30, once the user has 
selected an action from the list of actions 38, the con- 
version of the number 32 is performed according to the 
selected action. The converted number may then bedls* 
played to the user in a dialog box 37 as shown in FIG- 



URE 30. Alternatively, the number 32 may be replaced 
In the string of text with the converted nun^er ar>d the 
unit name associated with the destination unit of meas- 
urement. The number 32 may be replaced In the string 

5 of text using a document object model provided by the 
application program 205. This process is described in 
greater detaH below. Additk>nally. as will be discussed 
in greater detail below, the application program 205 re- 
ceives most of the text shown in the dropdown menu 36 

^0 from the action plug-In 225. This process occurs when 
the applk:atlon program 205 Is initially executed and the 
action plug-in 226 registers itself with the applteation 
program 205. Additional details regarding this registra- 
tion process will be described below with reference to 

IS FIGURE 4. 

[0051] Refening now to FIGURE 4. an illustrative rou- 
tine 400 will be described for registering the number 
conversion software components with the application 
program 205, in particular, when the actk>n plug-in 225 

20 and the recognizer plug-in 220 tor converting numbers 
are first executed, they are registered with the appfica- 
tk>n program 205. By registering with the application 
program 205, the application program 205 is nrmde 
aware of the software components and enabled for use 

25 with the schema types recognized by the recognizer 
plug-in 220. {Moreover, the action items to be displayed 
to the user correspor>ding to each schema type are also 
enumerated to the appHcation program 205 so that the 
application program 205 can display the dropdown 

30 menu 36 when a number 32 or Indicator 34 is selected 
by a user. 

[0052] The routine 400 begins at block 402, where the 
current user interface language is Identified. As dis- 
cussed briefly above, the current user interface lan- 

35 guage may be stored In the language settings 26 main- 
tained by the operating system 1 6 or the application pro- 
gram 205. Once the current user interface language has 
been kientified, the routine 400 continues to block 404. 
At block 404, the action plug-in 225 consults the con- 

40 version settings file 28, and generates action menu 
items for defined conversions that are specified for op- 
eration with all languages. In parficular, the action plug- 
in 225 creates action menu items for all defined conver- 
sions that include the phrase 'ALL' in the field 50A of 

45 the conversion settings file 28. The routine 400 then 
continues to block 406. 

[0053] At block 406, action menu items are also gen- 
erated for each defined conversion that has an entry in 
f reld 50A corresponding to the current user interface lan- 

50 guage. In this manner, action menu items are generated 
only for those conversions enabled for use with all user 
interface languages and for those conversions enabled 
for use with the current user interface language. It 
should be appreciated that the action menu Items are 

55 generated on a per source unit name basis. In this man- 
ner, many separate dropdown menus 36 may be gen- 
erated, one for each source unit name. Moreover, a sep- 
arate schema name is utilized for each source unit name 
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and current user interface language. In this manner, re- 
gardless of the source unit name or cunent user inter- 
face language, an appropriate dropdown menu 36 will 
be presented. 

[0054] From block 406. the routine 400 continues to 
block 408, where the action menu Items for each sche- 
ma are returned to the application program 205. Accord- 
ing to one embodiment of the invention, the application 
program 205 displays the dropdown menu 36 in re- 
sponse to the selection of a number 32 or an indicator 
34, However, It should l>e appreciated that the action 
plug-in 225 or other software component may be re- 
sponsible for the display of the dropdown menu 36. The 
routine 400 continues from block 408 to block 410, 
where it ends. 

[0055] Turning now to FIGURE 5, an illustratWe rou- 
tine 500 will be described for processing the input of a 
new string at the application program 205. The routine 
500 begins at btock 502. where the applk:atk>n program 
205 receives a new string, such as when a user enters 
a new paragraph into an electronic document or edits a 
prevk>U5ly entered paragraph. From block 502, the rou- 
tine 500 continues to block 504 where the appllcatton 
program 205 passes the new string to the recognizer 
DLL 210. As descn'bed above, the recognizer DU- 210 
is responsible for communicating with the application 
program 205, managing the jobs that need to be per- 
formed by the recognizer plug-ins 220A-220IM, receiving 
results from the recognizer plug-ins 220A-220N, and 
sending schema information to the application program 
module 205 for recognized numbers and source unit 
names. It should t>e understood that, in one embodiment 
of the Invention, a paragraph is passed to the recognizer 
DLL 210 at block 504. However, in altemative embodi- 
ments, a sentence, the contents of a spreadsheet cell, 
a section of the document, the entire document, etc., 
may be passed to the recognizer DLL 210. In other 
words, It should be appreciated that the embodiments 
of the present invention are not limited to simply passing 
a paragraph to the recognizer DLL 210. 
[0056] From block 504, the routine 500 continues to 
block 506, where the recognizer DLL 210 passes the 
string to the recognizer plug-ins 220A-220N.The routine 
500 then continues to block 608 where the recognizer 
plug-ins areexecuted on the paragraph to recognize key 
words or characters within the string. In partrcular, the 
recognizer plug-In for convening numbers between 
measurement systems is executed on the string. An il- 
lustrative routine describing the operation of the recog- 
nizer plug-in for number conversion is described below 
with reference to FIGURE 6. 

[0057] At block 510, the results from the recognizer 
plug-in 220 are received at the recognizer DLL 21 0. The 
routine 500 then continues to btock 512, where a deter- 
mination is made by the recognizer DLL 210 as to 
whether the paragraph has been edited since the siring 
was transmitted to the recognizer plug-ins 220A-220N. 
If the paragraph has been edited, the routine 500 returns 



to btock 504, where the edited string 1$ passed to the 
recognizer DLL 210. If the paragraph has not been ed- 
ited, the routine 500 continues to block 514. wttere the 
recognizer DLL 210 sends the results received from the 
5 recognizer plug-in 220 to Vt\B application program 205. 
The routine 500 then continues to block 516, where it 
ends. 

[0058] Refening now to FIGURE 6, an illustrative rou- 
tine 600 win be described that illustrates the operation 

to of the recognizer plug-in 220 for converting numbers be- 
tween units of measure according to one emt>odiment 
of the present invention. The routine 600 begins at block 
602, where a string of text is received at the recognizer 
plug-in 220 from the recognizer DLL 210. The routine 

15 600 then continues to block 604, where a detemiination 
is made as to whether the string of text contains a 
nunober. 

[0059] From block 604, the routine 600 continues to 
block 606, where a determination is made as to whether 

20 a numtmr was found rn the string of text. If no cfigrts were 
found, the routine 600 branches from block 606 to btock 
61 4. where it returns to block 51 0, shown in FIGURE 5. 
If, however, at block 606. it Is determined that digits were 
found In the string of text, the routine 600 continues to 

25 block 608. 

[0060] At block 608, text located after the identified 
digits is scanned to determine whether a source unit 
name is associated with the number. For example, the 
recognizer plug-in 220 may scan the text after the iden- 

30 titled digits for tfic source unit names 'km', "lb", 

and other source unit names. The list of the source unit 
names that the recognizer plug-in 220 searches for is 
defined by the field 50B of the conversion settings file 
28. 

05 [0061] From block -608 the routine 600 continues to 
blcx:k 610 where a detemiination is made as to whether 
a source unit name associated with the recognized 
number was kx^ated. If no source unit name was found, 
the routine 610 branches to block 614, where It returns 

40 to block 51 0, shown In FIGURE 5. If a source unit name 
was found that is associated with the recognized 
number, the routine 600 continues to block 612. 
[0062] At block 612, schema Informatton is returned 
to the recognizer DU. 21 0. In particular, a schema name 

45 associated with the soun^e unit nanr^ and the currently 
enabled language is returned to the recognizer DLL21 0. 
Additionally, a •property bag" may also be retumed to 
the recognizer DLL 210. The property bag is an object 
which stores infonnalion about the recognized number 

50 that may be utilized by the action plug-in 225. For in- 
stance, the property bag may include a format number 
indicaling generally which fonnat the recognized 
number was written in. Additionally, an index to the rec- 
ognized number within the string of text may also t>6 re- 

55 turned to the recognizer DLL 2 1 0. All of the Information 
retumed from the recognizer plug-in 220 to the recog- 
nizer DLL 210 may be subsequently passed to the ac- 
tion plug-in 225 and used in the conversion process. 
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This is described in greater detail below with resped to 
FIGURES 7 and 8. From block 612, the routine 600 con- 
tinues to block 61 4. wheie it returns to bkxsk 510, shown 
in FIGURE 5. 

[0063) Referring now to FIGURE 7, an illustrative rou- 
tine 700 will be described for processing the selection 
of a semantk^Ky categorized number having an asso- 
ciated unit name. As discussed above, once a number 
has been recognized within a string of text by the rec- 
ognizer plug-in 220A as having an associated unit 
name, the number may be highlighted or an indicatton 
may be provided to the user indk:ating that the number 
has been recognized and that anions may be perfomned 
on the number. Accordingly, at bbck 702. a detennina- 
tion is made as to whether the number or indicator has 
been selected by a user If the number has not been 
selected, the routine 700 continues to block 714, where 
it ends. If, however, the number or indwator has been 
selected, the routine 700 continues to bk>ck 704. 
[0064] At block 704, the applicatk)n program 205 dis- 
plays the list of actions associated with the schema cor- 
responding to the selected number. In this manner, the 
dropdown menu 36 described above with reference to 
FIGURE 3A is presented to the user. The rouUne 700 
then continues from block 704 to block 706, where a de- 
termination is made as to whether the user has selected 
one of the items from the list of actions. If the user has 
made the selection of a user interface item other than 
one of the items from the list of actions, the routine 700 
branches to block 710, where the list of actions is re- 
moved. If, however, the user does select one of the 
items from the list of actions, the routine 700 continues 
tobloc^708. 

[0065] At block 708, the application program 205 calls 
the action plug-in 226 corresponding to the appropriate 
schema type and indicates that an action item has been 
selected. The call from the application program 225 to 
the action plug-in 225 includes the schema name cor- 
responding to the recognized numl>er, the item number 
of the selected menu item, tiie name of the calling ap- 
plication program 205. a pointer into an object model 
provided by the application program 205 for accessing 
the document 24, the property bag described above with 
reference to FIGURE 6, and the text of the recognized 
number. The routine 700 then continues to block 712, 
where the action plug-in for converting numbers be- 
tween measurement units is executed. An illustrative 
routine for executing the action pkjg-in 226 for number 
conversion is described below with reference to FIG- 
URE 8. Once the action plug-in 226 has compieted its 
execution, the routine 700 continues from block 712 to 
block 714, where It ends. 

[0066] Referring now to FIGURE 8, an illustrfiitrve rou- 
tine 800 will be described for executing an action plug- 
in 225 tor converting numbers between measurement 
systems. The routine 800 begins at block 802, where 
the action plug-in 225 receives a call from the action OIL 
215 indicating that the user has selected an action menu 



Item. From bk)ck 802, the routine 800cominuesto block 
604, where the action plug-in 225 determines the actual 
value of the recognized number in view of a format as- 
sociated with the language in which the string containing 

6 the number is expressed. This is necessary because 
numbers expressed in different languages may include 
separator characters that have different meanings in dif- 
ferent languages. For instance, a numtier may be ex- 
pressed in French as •1,729', whfle in English it would 

10 be expressed as "1729.' Therefore, at block 804, the 
action plug-tn 225 identifies the regional format for the 
number from the language settings file 26 based on the 
language in which the number is expressed. Using the 
regional format, the actual value of the number can be 

15 determined. 

[0067] From block 804, the routine 800 continues to 
bbck 808. where the recognized number is converted 
to the destination unit of measure according to the se- 
lected action menu item. In particular, the value of the 

20 field 50J of the conversion settings file 28 for the select- 
ed conversion may be utilized to convert the recognized 
and selected number. The value of the field 501 in the 
conversk>n settings file 28 may also be utilized to round 
the converted number to the appropriate number of dig- 

25 Its. 

[0068] From block 806, the routine 800 continues to 
block 808. where the converted number is formatted. 
The converted number may be formatted according to 
the regional format specified in the language settings 

30 fite26. Moreover, the valueoffieldSOKintheconversion 
settings file 28 may be utilized to f omiat the spacing be- 
tween the converted number and the destination unit 
name. Other types of fonnatting may also be applied to 
the converted number. 

35 [0069] From block 808, the routine 800 continues to 
block 810 where the number in the string of text Is re- 
placed with the converted number. According to one em- 
bodiment of the present invention, the replacement Is 
made by accessing a document object model provided 

40 by the application program 205. Through tlie document 
object model, the action plug-in 225 can directly access 
the document 24 and make changes therein. Details re- 
garding the use of such a document object model are 
well known to those skOled In the art. Alternatively, the 

45 converted number and Its associated unit name may be 
displayed to the user. From block 810, the routine 800 
continues to block 812, where it returns to block 714. 
described above with reference to FIGURE 7. 
[0070] Based on the foregoing, those skilled in the art 

50 Should appreciate that various embodiments of the 
present invention provide a method, system, apparatus, 
and computer-readable medium for converting numbers 
between units of measure based upon semantrcally la- 
beled strings. The above specification, examples and 

55 data provide a complete description of the manufacture 
and use of the composition of the invention . Since many 
embodiments of the Invention can be made without de- 
parting from the spirit and scope of the invention, the 
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invention resides in the claims hereinafter appended. 



Claims 

1. In a system for creating and editing an electronic 
document, a method lor converting a number be- 
tween two systems of measurement, the method 
comprising: 

detemiining whether a string of text contained 
within the electronic document contains a 
number having an associated unit name; 
in response to detennining that the string of text 
includes a number having an associated unit 
name, semantically labeling the number with 
schema information identifying the unit name 
as a source unit of measure; 
providing a list ot actions that may be performed 
on the number to convert the number to a des- 
tination unit of measure, the list of actions iden- 
tified based upon the schema information: 
receiving a selection of an action from the list 
of actions; and 

generating a converted number by converting 
the number from ttie source unit of measure to 
the destination unit of measure identified by the 
selected action. 

2. The method of Claim 1 , wherein operating a con- 
verted number by converting the number from the 
source unit of measure to the destination unit of 
measure identified by the selected action compris- 
es: 

retrieving from a conversion settings file a con- 
version ratio or formula corresponding to the 
selected action; and 

generating a converted number by converting 
the number from the source unit of measure to 
the destination unit of measure with the conver- 
sion ratio or formula. 

3. The method of Claim 2, wherein the conversion set- 
lings file comprises a conversion ratio or formula 
corresponding to one or more measurement con- 
versions, and wherein the method further compris- 
es receiving from a user a user-defined conversion 
ratio or formula and storing the user-defined ratio 
or formula in the conversion settings file. 

4. The method of Claim 1 , further comprising: 

replacing the number and the associated unit 
name with the converted number and a unit 
name associated with the destination unit of 
measure. 



.5. The method of Claim 4. wherein replacing the 
numt>er and the associated unit name with the con- 
verted number and a unit name associated with the 
destination unit of measure comprises utflizing a 
5 document object model provided by an application 
for editing the electronic document to replace the 
number and the associated unit name with the con- 
verted number and a unit name associated with the 
destination unit of measure. 

10 

6. The method of Claim 5, wherein the list of actions 
comprises a dropdown menu having one or more 
menu items conesponding to the list of actiwis tt^t 
may be performed on the number to convert the 

15 number to the destination unit of measure. 

7. The method of Claim 6, further comprising: 

determining a current user interface language 
20 setting for the application; and 

generating the menu Items of the dropdown 
menu in a language specified by the current us- 
er interface language setting . 

25 8. The method of Claim 7, wherein generating the 
menu Items of the dropdown menu comprises: 

generating menu items enabled for use with all 
languages; and 
30 generating menu items enabled for use with the 

language specified try the cunrent user interface 
language setting. 

9. The method of Claim 8. further comprising display- 
35 ing the number and an indication that the number 
has been semantically labeled, and wherein the list 
of actions Is provided in response to the selection 
of the number or the Indication. 

40 10. The method of Claim 9, wherein the schema infor- 
mation comprises data uniquely corresponding to 
the source unit of measure and the language spec- 
ified by the current user interface language setting. 

45 11. The method of Claim 10, further comprising: 

determining a value of the number prior to con- 
verting the number based upon a format asso- 
ciated with the language in which the string of 
50 text is expressed. 

12. A computer-readable medium comprising compu- 
ter-readable instructions which, when executed by 
a computer, cause the computer to perform the 

55 method of Claim 2. 

13. A compuler-conln>lled apparatus capable of per- 
forming the method of Claim 2. 



21 



EP 1361 523 A2 



,22 



14. In a system for creating and editing an electronic 
documerft, a method for converting a number be- 
tween two systems of measurement, the method 
comprising: 

5 

receiving a portion of the electronic document 
as a string of text; 

analyzing the sinng of text to determine wheth- 
er the string of text includes a number having 
an associated unit nanra; 
in response to detennining that the string of text 
includes a number having an associated unit 
name, semantically labeling the number with 
schema Information Identifying the unit name 
as a source of measure; 
displaying the numl)er and the unit name and 
an indication that the numt>er has been seman- 
tically labeled; 

receiving a selection of the number or the Indi- 
cation; ^ 
in response to receiving the selection of the 
number or the indication, providing a list of ac- 
tions that may be performed on the number to 
convert the number to a destination unit of 
measure; 

receiving the selection of an action from the list 
of actions; 

In response to receiving the selection of an ac- 
tion, determining a value for the number based 
upon a fomriat associated with a language in 
wtiich the string of text is expressed; 
generating a converted number by converting 
the value to the destination unit of measure 
identified by the selected action; and 
replacing the number with the converted 3S 
number in the string of text. 

15. The method of Claim 14, wherein the list of actions 
comprises a dropdown menu having one or more 
menu items corresponding to the list of actions that 4(7 
may be performed on the number to convert the 
number to the destination unit of measure. 

16. The method of Claim 15, further comprising: 

45 

detenrtining a current user Interface language 
setting tor an application program associated 
with the electronic document; and 
generating the menu items of the dropdown 
menu in a language specified by the current us- ^ 
er interface language setting. 

17. The method of Claim 16, wherein generating the 
menu Items of the dropdown menu comprises: 

55 

generating menu items enabled for use with all 
languages; and 

generating menu items enabled for use with the 



language specified by the current user interface 
language setting. 

18. A computer-readable medium comprising compu- 
ter-readable instructions which, when executed by 
a computer, cause the computer to perform the 
method of Claim 14. . 

19. A computer-controlled apparatus capable of per- 
fomwng the method of Claim 14. 

20. A system for converting a number between two sys- 
tems of measurement, the system comprising: 

a recognizer plug-in capable of receiving a por- 
tion of an electronic document as a string of text 
from an application program, analyzing the 
string of text to detennine whether the string of 
text includes a number having an associated 
unit name, and in response to determining that 
the string of text tndudes a number having an 
associated unit name, semantically labeling the 
number with schema inf onrrwtion Identifying the 
unit name as a source unit of measure and 
Identifying the language used to express the 
string of text; 

an application program for creating and editing 
the electronic document, the application pro- 
gram capable of displaying the string of text and 
an incfication that the number has t>een seman- 
tically lat)eled, receiving a selection of the 
number or the indication, in response to receiv- 
ing the selection of the number or the indica- 
tion, providing a list of actions that may be per- 
formed on the number to convert the number to 
a destination unit of measure, receiving the se- 
lection of an action from the list of actions, and 
providing the selected action and the number 
to an action plug-in; and 
an action plug-In capable of generating a con- 
verted nunr^er by converting the number to the 
destination unit of measure identified by the se- 
lected action, and replacing the number with 
the converted number and a unit name corre- 
sponding to the destination unit of measure in 
the string of text. 

21. The system of Claim 20, wherein the list of actions 
comprises a dropdown menu having one or more 
nr>enu items corresponding to the list of actions that 
may be performed on the number to convert the 
number to the destination unit of measure, and 
wherein the action plug-In Is further operative to: 

determine a cun-ent user interface language 
setting for the application program; and to 
generate the menu items of the dropdown 
menu in a language specified by the current us- 
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er interface language setting. 

22. The system of Claim 21 , wherein the action plug-In 
Is further operative to Identify one or more enabled 
languages for the application program and to gen* 
erate menu items enabled for use with all languag- 
es, and to generate menu items enabled for use 
with the language specffied by the current user In- 
terface language setting. 
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